package yl.hs.bmipfull.service.material;

import org.springframework.web.bind.annotation.RequestBody;
import yl.hs.bmipfull.pojo.material.RawMaterialInventoryEntity;
import yl.hs.bmipfull.service.IBaseService;
import yl.hs.bmipfull.viewmodels.PageQuery;
import yl.hs.bmipfull.viewmodels.PageResult;

import java.util.List;
import java.util.Map;

/**
 * 作用:  原材库存信息表服务层接口<br/>
 * 创建时间: 2021年05月19日 09时47分31秒 <br/>
 *
 * @author 张凯
 */

public interface IRawMaterialInventoryService extends IBaseService {

    /**
     * 查询原材库存信息表信息
     *
     * @param pageQuery 查询条件 {@link PageQuery}
     * @return 原材库存信息表-List<{@link RawMaterialInventoryEntity}>
     * @throws Exception 查询参数异常
     */
    List<Map<String, Object>> queryList(PageQuery pageQuery) throws Exception;

    /**
     * 查询原材库存信息表信息
     *
     * @param pageQuery 查询条件 {@link PageQuery}
     * @param rowNum    每页条数
     * @param page      页码
     * @return 站内信息-List-SiteMessageMainEntity
     * @throws Exception 查询条件异常
     */
    PageResult<RawMaterialInventoryEntity> queryPage(PageQuery pageQuery, int rowNum, int page) throws Exception;


    /**
     * 根据原材库存信息表编号查询原材库存信息表信息
     *
     * @param sn 编号
     * @return 原材库存信息表-{@link RawMaterialInventoryEntity}
     */
    RawMaterialInventoryEntity findBySn(String sn);
    /**
     * 根据原材编号查询原材库存信息表信息
     *
     * @param sn 原材编号
     * @return 原材库存信息表-{@link RawMaterialInventoryEntity}
     */
    List<Object> findByRawSn(String sn);
    /**
     * 保存原材库存信息表信息
     *
     * @param model 原材库存信息表表单信息
     * @param sn    原材库存信息表信息原有编号
     * @return 执行结果-受影响行数-Integer
     * @throws Exception 保存异常
     */
    Integer saveRawMaterialInventory(@RequestBody Map<String, Object> model, String sn) throws Exception;

    /**
     * 根据原材库存信息表编号删除原材库存信息表信息
     *
     * @param sn 原材库存信息表编号
     * @return 影响行数
     */
    Integer delete(String[] sn);

    /**
     * 根据原材库存信息编号修改状态
     *
     * @param snArray 原材库存信息编号数组
     * @param state   状态
     * @return 受影响行数
     */
    Integer changeStateBySn(String[] snArray, short state);

    List<RawMaterialInventoryEntity> queryByWouSN(String sn);
}